package com.cyx.mapper;

import com.cyx.pojo.Student;
import com.cyx.pojo.StudentQueryParam;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;

import java.util.List;
import java.util.Map;

@Mapper
public interface StudentMapper {

    /**
     * 条件分页查询学生信息
     *
     */
    List<Student> list(StudentQueryParam studentQueryParam);

    /**
     * 添加学生信息
     * @param student 学生信息
     */

    void insertStudent(Student student);

    /**
     * 根据id查询学生信息
     * @param id 学生id
     * @return 学生信息
     */
    Student getStudentInfoById(Integer id);

    /**
     * 修改学生信息
     * @param student 学生信息
     */
    void updateStudent(Student student);

    /**
     * 批量删除学生信息
     * @param ids 学生id列表
     */
    void deleteStudentByIds(List<Integer> ids);

    /**
     * 添加学生违规信息
     * @param id 学生id
     * @param score 违规分数
     */

    void violationStudent(@Param("id") Integer id,@Param("score") Short score);

    /**
     * 查询指定班级下的学生数量
     * @param clazzId 班级ID
     * @return 学生数量
     */
    @Select("SELECT COUNT(*) FROM student WHERE clazz_id = #{clazzId}")
    int countByClazzId(Integer clazzId);


    /**
     * 查询每个班级学生数量
     *
     */
    List<Map<String, Object>> countStudentData();

    /**
     *  查询所有学生的薛莉莉分布
     */
    List<Map<String, Object>> countStudentDegreeData();
}
